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Description 

[0001 ] This invention relates to browser proxies that transform image objects embedded inside documents, it is more 
generally related to any proxy or gateway system that processes MIME encapsulated objects and the world wide web. 
5 [0002] Transcoding proxies sometimes act as intermediaries between web servers and a variety of client devices 
that are connected over communication links with widely varying characteristics. Generally, a transcoding proxy pro- 
vides two major benefits: dramatic reduction in download times for low-bandwidth links, and tailoring of web data to 
the client device. 

[0003] Mobile devices are frequently connected via low-bandwidth wireless or medium bandwidth wireline modem 

'0 links that make the viewing of rich web content, such as images, very cumbersome due to the very long download 
times that result. In addition, the cost of such downloads can be prohibitive over tariffed wide-area wireless networks. 
Transcoding web proxies can reduce the size of web data while maintaining most of its semantic value. Download time 
reductions of six to ten times may be achieved for many typical web images without losing their intelligibility. 
[0004] The second important benefit is that such an intermediate proxy is sometimes also capable of tailoring text 

is and images for the multitude of small, weakly connected, but web-enabled, mobile devices that are now available. The 
capabilities of these mobile devices to receive, process, store and display web content varies widely. Given the variety 
of client devices, it is difficult for Internet content publishers to tailor content for the individual devices. Consequently, 
an active web proxy is used to transcode/change the web content to best fit the resolution, color-depth, and size 
constraints of a small-screened device and to reduce the size of the stored data to a fraction of its original size. 

20 [0005] A typical transcoding web proxy may be implemented by adding a transcoding module in an HTTP proxy. The 
transcoding module is an input/output system that takes a data object (e.g., an image or HTML page) as input and 
transforms it into a low resolution object (e.g., a low-quality image or summarized HTML page) according to a set of 
chosen parameters. These parameters are input to the transcoder, which determines the resolution loss and size 
reduction of the object. The following discussion is mostly concerned with image objects. 

25 [0006] To maximize the benefits of transcoding, it is important to choose the quality Vs. size tradeoff such that the 
best quality image is sent within the delay tolerance specified by the user. Choosing the right set of transcoding pa- 
rameters, however, is difficult. First, it is hard to estimate the size of the transcoded image size because the degree of 
compression achieved through transcoding is content dependent. For example, some JPEG files can be compressed 
by up to 80% while others may only yield less than 5% compression. The same is true when GIF-to-GIForGIF-to-JPEG 

30 transformations are applied. Since transcoding is a compute-intensive process, processing is only worthwhile when 
high compression ratios can be achieved. For images that are already well-compressed (or of low quality) transcoding 
may be wasteful. 

[0007] Even if the size of the transcoded output can be predicted, network variability makes it hard to predict image 
download times. Since the user perceived quality and latency are the final performance measures, accurate estimates 
35 of download times are needed in order to choose the optimal point in the quality Vs. size tradeoff. Over best effort 
service networks, such as the Internet, accurate estimates of network characteristics (bandwidth, delay, loss rate) are 
hard to compute. Often the variance is so large that the statistical estimates are not meaningful for making any quality 
adjustments. 

[0008] Another issue that makes policy decisions a complicated task is the location of the bottleneck in the network. 
40 When the path between the web server and the proxy is the bottleneck, transcoding does not help at all. On the contrary, 
it makes things worse due to the store and forward nature of the operation. Ideally, web proxies should stream images 
from web servers to clients whenever the server to proxy path is the bottleneck. Even in cases where the proxy to client 
path is the bottleneck, any benefit due to size reduction must be weighed against the store and forward delay incurred 
due to transcoding. 

45 [0009] Due to the difficulty of estimating the network characteristics and image content, transcoding proxies may 
often only support adaptation at a very coarse level. Adaptation involves changing transcoding parameters which are 
usually selected from a predefined set of defaults, or chosen by the user. The problem with both approaches is that 
the full potential of transcoding is not utilized. Predefined static policies are unresponsive to changes in network band- 
width and user selectable policy decisions are likely to be sub-optimal due to the lack of knowledge about the state of 

50 the network. No method exists for providing feedback to the user about the combined state of the network and the 
proxy. Using iterative refinement, users can converge to the optimal choice of transcoding parameters, but such a 
process is time consuming and not very user-friendly. 

[0010] Figure 1 shows an example transcoding proxy scenario 100 with varied links and varied client devices. As 
shown in Figure 1 , we consider an example scenario in which all of the web requests and responses for clients 1 30-1 34 
55 are passed through a generic (Hypertext Transfer Protocol) HTTP proxy 190. In the example scenario of Figure 1 , it 
is the downloading of large data objects, primarily images, over the last link 160-164 from the proxy to the client that 
typically is the main source of delay in the end-to-end response time experienced by the clients 130-134. 
[0011] The transcoding proxy 190 provides massive data thinning of web data to enable real-time browsing of web 
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data over low-speed wide-area wireless links, like Cellular Digital Packet Data (CDPD) 163 that provides 10 kb/s or 
less of throughput, depending upon the number of clients sharing the link. The end client could be a full-function PC 
134 with a good color display, so that the primary problem is bandwidth reduction. Alternatively, the client might be a 
small, web-enabled, mobile devices 130-132 in which case it is advantageous to tailor the web data for the specific 
client device, particularly the client's display characteristics. Different aspects of transcoding proxy design benefit dif- 
ferent scenarios (i.e., tariffed proxy-client link, strong/weak client display, etc.), but all are handled well within the same 
proxy architecture 100. 

[001 2] Figure 2 shows a block diagram of an embodiment of transcoding proxy 1 90 used to transform objects based 
on user specified preferences and static policies. A transcoding proxy 1 90 is built by combining a transcoding module 
240 with an HTTP proxy engine 220. An HTTP request 222 originates from a client 230 and is forwarded 224 by the 
proxy 1 90 to a web server 21 0. The response data 226 (i.e., HTML pages and GIF and JPEG images) are transformed 
by the transcoder 240 and then forwarded 228 to the client 230. Typically, a number of transcoding parameters are 
specified to the transcoder 240 in order to achieve the desired quality/size reduction of the object contained in the 
response data 226. Transcoding proxies in use today either use a static set of policies 250 or use some form of user 
specified preferences 260 via path 265 to determine the transcoding parameters. When a fixed set of transcoding 
parameters are applied to all objects, results are not always beneficial. In fact, in many cases, transcoding leads to 
poorer performance. 

[001 3] The international patent application WO 98/431 77 describes a system for dynamically transcoding data trans- 
mitted between a network server and a network client over a communications link. The system includes a parser 
coupled to a transcode service provider, the parser being configured to selectively invoke the transcode service provider 
in response to a predetermined selection criterion. The selection criterion may be a characteristic of the data being 
transmitted, a characteristic of the communications link, a characteristic of the network server, a characteristic of the 
network client or a user preference. The network characteristics include best-case, worst-case and average latency 
and the user preferences include preferred content quality/speed tradeoff. The amount of data that is transmitted to 
the network client may be reduced thereby promoting faster downloading and rendering of content. 
[0014J There is now provided, according to the present invention, a method as defined in claim 1 . 
[0015] Preferably, the network characteristics include bandwidth, and examining network characteristics includes 
estimating network bandwidth between said one of the servers and the proxy as well as between the proxy and said 
one of the clients. 

[0016] Preferably, the network characteristics include delay, and the step of examining network characteristics in- 
cludes estimating delay between said one of the servers and the proxy as well as delay between the proxy and said 
one of the clients. 

[0017] The method preferably further comprises providing feedback to the user about a level of transcoding per- 
formed on the object to form the transcoded form. 

[0018] Preferably, the step of examining includes determining the size of the object. 

[0019] In the method as described the object may be of type image forming an image object, and the method further 
comprises: determining dimensions of the image object, and calculating the compression ratio of the image object. 
Further to be preferred is that the dimensions of the image object are determined by area of the image in square pixels, 
and the compression ratio is determined by the bpp ratio of the image object. 
[0020] The step of forming a transcoded form preferably employs dynamic adaptation. 

[0021] The step of forming a transcoded form is preferably started before the step of receiving the object from said 
one of the servers is complete. The received object type is preferably of type JPEG forming a JPEG object. Further to 
be preferred is that the step of forming a transcoded form includes performing JPEG-to-JPEG image transcoding and 
the step of sending the transcoded form starts writing out at least one MCU of JPEG-encoded output image data before 
the step of receiving the object is complete. 

[0022] In the method as described, the step of sending out the transcoded form is preferably started after processing 
an initial fraction of the received object, and before the step of receiving the image object from said one of the servers 
is complete. 

[0023] The step of sending out the transcoded form is preferably started before the step of forming a transcoded 
form of the object is complete. 

[0024] In a second aspect, the present invention provides a method for a proxy to form a transcoded form of an 
object received from a server in satisfaction of a request from a client for an object available from the server, the method 
comprising dynamically adapting parameters for transcoding the object for the client, forming a transcoded form of the 
object, and sending the transcoded form to the client. The step of adapting parameters preferably includes determining 
at least one characteristic of the object. One characteristic is preferably an object-header, the object-header providing 
information about the size and the type of the object. The method preferably further comprises comparing the size of 
the object to a threshold parameter called "sizejhreshold". The step of adapting parameters preferably includes gath- 
ering present network characteristics between the server and the proxy and between the proxy and the client. One of 
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the characteristics is preferably network bandwidth and the step of adapting includes estimating network bandwidth 
between the server and the proxy as well as between the proxy and the client. 

[0025] In the method as described, the transcoded form is preferably dependent upon the estimated bandwidth. The 
step of adapting also preferably includes retrieving preferences of the user, and wherein the transcoded form is de- 
5 pendent upon the preferences. The step of adapting preferably includes examining the contents of the object. The 
object is preferably of type image forming an image object, and examining the content of the image object includes 
determining dimensions of the image. 

[0026] In the method as described, the step of adapting is preferably dependent upon determining the compression 
ratio of the image object. The type of image object is further preferably GIF and wherein the step of adapting is de- 

10 pendent upon comparing the compression ratio against a predetermined policy threshold called "gifjhreshold". 

[0027] The method as described preferably further comprises predicting at least one parameter of the transcoded 
form of the object. The transcoded form is further preferably the same as an original form of the object. Preferably, at 
least one of the parameters includes a size of the transcoded form. Preferably also, at least one of the parameters 
includes the time spent in transcoding the object. 

*5 [0028] In a third aspect, the present invention provides a method for predicting parameters of a transcoded form of 
an object, the object having an initial size and dimension, and the object being received from a server in satisfaction 
of a request from a client for the object, the method comprising: computing the bpp ratio of the object, gathering a set 
of statistics of a plurality of previously transcoded objects, and employing the set of statistics and the bpp ratio for 
predicting the parameters. 

20 [0029] In a method as described, at least one of the parameters is preferably size and the set of statistics includes 
sizes of a plurality of previously transcoded objects statistics. 

[0030] The object is preferably of type image and the set of statistics includes image quality. The plurality of previously 
transcoded objects are preferably chosen from a predetermined benchmark suite of images. 
[0031] In a method as described, the step of employing preferably uses dynamically updating the set of statistics 
25 using the statistics of the currently transcoded object. At least one of the parameters is preferably a duration for forming 
a transcoded form of an object and the set of statistics includes the duration for forming a plurality of previously trans- 
coded objects. 

[0032] In a fourth aspect, the present invention provides a transcoding proxy system for facilitating browsing between 
a plurality of clients and a plurality of servers connected via a communication network, the proxy comprising an HTTP 

30 proxy engine to receive a request from one of the clients for an object stored at one of the servers, and to fetch the 
object from said one of the servers, an object transcoder to form a transcoded form of the object using a set of param- 
eters for transcoding, a dynamic policy module to determine the set of parameters of transcoding, an image size and 
delay predictor module to gather characteristics of the object, a user preference module to gather quality preferences 
specified by a user of said one of the clients, and a bandwidth estimation module to estimate available network band- 

35 width, wherein dynamic policy module dynamically adjusting the parameters of transcoding using the input received 
from the image size and delay predictor module, user preferences module, and bandwidth estimation module for the 
purpose of improving satisfaction for the user, and the transcoding system providing feedback to the user about the 
level of transcoding performed. 

[0033] The user preferences module preferably further collects the characteristics such as display size, resolution, 
40 & CPU speed of said one of the devices, and provides those characteristics to the dynamic policy module. 

[0034] In the system as described, the bandwidth estimation module preferably collects traces of previously estab- 
lished network connections between said one of the servers & the proxy, collects traces of previously established 
network connections between the proxy and said one of the clients, and estimates the object download time by per- 
forming statistical analysis on the collected traces. 
45 [0035] The statistical analysis used for estimating bandwidth between said one of the servers and the proxy is pref- 
erably based on computing a statistical measure such as median, mean, or mode of download times of previously 
fetched objects as determined from the collected traces. 

[0036] The statistical analysis used for estimating bandwidth between the proxy and said one of the clients is pref- 
erably based on computing aggregate bandwidth of all active connections between the proxy and said one of the 

so clients. The system preferably further comprises displaying a slide bar on said one of the client's display for collecting 
the user specified preferences. In a system as described, the user of said one of the clients can preferably specify the 
tradeoff between download time and data quality through the use of a graphical user interface with a slide bar. The 
user of said one of the clients can preferably specify through the use of a graphical user interface with a slide bar the 
tradeoff between download time and image quality including a specific switch to select color or gray scale as the desired 

55 output form. The user of said one of the clients can further preferably specify through the use of a graphical user 
interface with a slide bar, the desire to maintain a target response time such that the system automatically reduces 
data quality (and hence data download size) to compensate for dynamic variations in bandwidth to said one of the 
clients. The graphical user interface slider bar is also preferably used as an output interface for showing the optimal 
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choice of transcoding parameters to the user. 

[0037] In a fifth aspect, the present invention provides an article of manufacture comprising a computer usable me- 
dium having computer readable program code means embodied therein for causing dynamic adaptation of transcoded 
form of an object in a transcoding proxy, the computer readable program code means in said article of manufacture 
comprising computer readable program code means for causing a computer to effect: a proxy receiving an object 
associated with a user from a server, determining parameters of the object, retrieving preferences of the user, gathering 
present network characteristics, obtaining transcoding policy thresholds, performing a policy decision based upon ob- 
ject parameters, user preferences, network characteristics, and policy thresholds, forming a transcoded object, pro- 
viding feedback of a level of transcoding performed on the object to the user, and sending the transcoded object to the 
user. 

[0038] In a sixth aspect, the present invention provides an article of manufacture comprising a computer usable 
medium having computer readable program code means embodied therein for causing a transcoding proxy to facilitate 
browsing between a plurality of client devices and a plurality of servers connected via a communication network, the 
computer readable program code means in said article of manufacture comprising computer readable program code 
means for causing a computer to effect: receiving a request from one of the client devices for an object stored at one 
of the servers, forwarding the request for the object to said one of the servers, receiving the object from said one of 
the servers, examining preferences specified by a user of said one of the client devices, examining contents of the 
object, examining communication network characteristics, choosing a set of transcoding parameters, forming a trans- 
coded form of the object, and sending the transcoded form to said one of the clients. 

[0039] The computer readable program code means in said article of manufacture preferably further comprises com- 
puter readable program code means for causing a computer to effect providing feedback to the user about a level of 
transcoding performed on the object to form the transcoded form. The computer readable program code means in said 
article of manufacture preferably further comprises computer readable program code means for causing a computer 
to effect determining dimensions of the object, and calculating the compression ratio of the object. The computer 
readable program code means in said article of manufacture preferably further comprises computer readable program 
code means for causing a computer to effect starting the step of forming a transcoded form before the step of receiving 
the object from said one of the servers is complete. 

[0040] In a seventh aspect, the present invention provides a computer program product comprising a computer 
usable medium having computer readable program code means embodied therein for causing a proxy to form a trans- 
coded form of an object received from a server in satisfaction of a request from a client for an object available from 
the server, the computer readable program code means in said computer program product comprising computer read- 
able program code means for causing a computer to effect: dynamically adapting parameters for transcoding the object 
for the client, forming a transcoded form of the object, and sending the transcoded form to the client. 
[0041] The computer readable program code means in said computer program product preferably further comprises 
computer readable program code means for causing a computer to effect gathering present network characteristics 
between the server and the proxy and between the proxy and the client. The computer readable program code means 
in said computer program product preferably further comprises computer readable program code means for causing 
a computer to effect adapting parameters for transcoding based upon the estimated bandwidth and preferences of the 
user. 

[0042] In an eighth aspect, the present invention provides a program storage device readable by machine, tangibly 
embodying a program of instructions executable by the machine to perform method steps for predicting parameters 
of a transcoded form of an object, the object having an initial size and dimension, and the object being received from 
a server in satisfaction of a request from a client for the object, said method steps comprising: computing the bpp ratio 
of the object, gathering a set of statistics of a plurality of previously transcoded objects, employing the set of statistics 
and the bpp ratio for predicting the parameters. 

[0043] Said method step of employing the set of statistics preferably further comprises updating the set of statistics 
using the statistics of the currently transcoded objects. 

[0044] An aspect of the present invention is to provide methods, devices and systems for dynamically adjusting 
transcoding parameters so as to increase the benefits of transcoding. Methods of adaptation are designed to cope 
with the variability of network characteristics and of the size of transcoded images. 

[0045] In an embodiment, the invention includes three new components: an image size predictor, a network band- 
width (b/w) analyzer, and a policy module. Before initiating any transcoding action, the policy module queries the image 
size predictor to estimate the size of the output image. The b/w analyzer is queried to collect an estimate of the image 
transmission time from the server to the proxy, and from the proxy to the client. Based on the collected estimates, the 
proxy decides whether or not to transcode the image. In addition, the policy module can also compute the optimal point 
in the quality vs. size tradeoff that would provide the user specified performance criteria (e.g., reduced response time, 
increased quality). 

[0046] Another aspect of the present invention is to provide a method and/or apparatus to enable the transcoding 
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proxy to adjust a quality-size tradeoff on a per-image and/or a per-client basis. The adaptive transcoder chooses dif- 
ferent parameters for each object, and provides performance improvements. 

[0047] Still another aspect of this invention provides a general framework for making policy decisions taking into 
account available bandwidth, content and type of image, and user preferences. The administrator of the proxy chooses 
5 from a variety of optimization objectives so as to obtain improved performance from the system. In one embodiment 
when the proxy transcoder throughput is the bottleneck, the policy module is instructed to judiciously use CPU resources 
so as to reduce the response time for all users. An advantageous element of the invention is the automated nature of 
decision making, to free up users from actively controlling the policy engine of the proxy. 

[0048] In still another aspect of the present invention a method is provided for generating feedback about the choice 
io of optimal transcoding parameters to the user. In an example of embodiment, the transcoding system provides feedback 
to the user by dynamically adjusting the position of the user preference slider bar. The user preference slider bar serves 
both as an input as well as an output device. 

[0049] A preferred embodiment of the present invention will now be described by way of example, with reference to 
the drawings in which: 

15 

FIG. 1 shows an example transcoding proxy scenario with varied links and varied client devices; 

FIG. 2 shows a block diagram of a transcoding proxy used to transform objects based on user specified preferences 
and static policies; 

20 

FIG. 3 shows a block diagram of an example of a transcoding proxy modified in accordance with the present 
invention to include an image size predictor, bandwidth estimator, dynamic policy module, and a user feedback 
generator; 

25 FIG. 4 shows an example block diagram of an example HTTP proxy with caching and transcoding modules in 

accordance with the present invention; 

FIG. 5 shows an example flow diagram of a transcoding dynamic policy module in accordance with the present 
invention; 

30 

FIG. 6 shows an example web request-response cycle using a transcoding proxy in accordance with the present 
invention; 

FIG. 7 shows an example regime where transcoding is useful in accordance with the present invention; 

35 

FIG. 8 shows an example flow diagram of a example policy function in accordance with the present invention 

FIG. 9 shows an example block diagram of an example image size prediction module in accordance with the 
present invention; 

40 

FIG. 10 shows an example block diagram of an example bandwidth prediction module in accordance with the 
present invention; 

FIG. 11 shows input/feedback user interface in accordance with the present invention; and 

45 

FIG. 12 illustrates an example timing diagram of streaming transcoding in accordance with the present invention. 

[0050] Figure 3 shows a block diagram 300 of an example embodiment of changes to transcoding proxy 190 in 
accordance with the present invention. A comparison of Figure 3 to Figure 2 shows a replacement of the static policy 

50 module, 250 in Figure 2, with a dynamic policy module, 370 in Figure 3. A purpose of the dynamic policy module 370 
is to make decisions concerning when to turn transcoding on and off and what transcoding policy (i.e., the transcoding 
algorithm along with its parameters) to use. The dynamic policy module 370 also interfaces with an image size and 
delay predictor 375, a bandwidth estimator 380, and a user feedback provider 390. In the embodiment shown, the 
policy module 370 employs a number of criteria, including: the characteristics of the data (e.g., size of the images, 

55 current encoding efficiency, structural role in the HTML page) as determined by the content analysis flow diagram 
(shown in Figure 5), the current estimate of the bandwidth on the proxy-to-client and server-to-proxy links (shown in 
Figure 10), the characteristics of the client, particularly the client display capabilities, and the user preferences con- 
cerning the preferred rendering of the data (shown as the user slide bar preferences in Figure 11). 
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[0051] The items shown in Figures 5, 10 and 11 are described below. In particular, the user slide bar preferences of 
Figure 1 1 , provide a method of interacting with the transcoding proxy so as to dynamically change the tradeoff between 
image quality and download time. In addition to serving as an input interface, the slider bar (1140 1150 1160 of Figure 
1 1 ) also acts as an output interface, displaying the feedback 390 that is received from the dynamic policy module 370 
[0052] Figure 4 shows a block diagram 400 illustrating an example function of a multi-resolution cache 410 in a 
transcoding HTTP proxy system 400 in accordance with the present invention. Caches are useful in HTTP proxies to 
provide reduced response time for repeated data requests (by the same or different clients) for the same data object 
A variety of methods may be used to assure that the cached data is up-to-date. In the example caching transcoding 
system 400, the multi-resolution cache 410 stores an original version of the data, as well as other possible forms of 
the data, including reduced resolution versions that have been transcoded for specific device types. 
[0053] As an example, we again consider the case of an image data object, but it is understood by those skilled in 
the art that these methods can be applied to other data types. We describe a method for storing, tagging and retrieving 
various forms of the data in the context of a caching transcoding proxy system. 

[0054] Referring to Figure 4, it is assumed that a JPEG image is received from the server 210 in response to a 
request by a client 230. This image is decoded from the lossy JPEG encoding format to a bit-map representation of 
the image. Those skilled in the art of image processing recognize that the JPEG encoding standard describes images 
using coefficients that weight Discrete Cosine Transforms (DCTs) so a compute-intensive decoding step is generally 
required to obtain the actual colors of each pixel. This bit-map requires a larger storage size than the original JPEG 
image. However, given an adequate size cache it may be worthwhile to store (via data path 420) this expanded size 
image so as to avoid the compute-intensive step of JPEG decoding when a transcoded version of the same image is 
later required but with different transcoding parameters than the first request. In a second step, based on the transcoding 
parameters (i.e., color depth, scaling factor, and the JPEG quality factor) the JPEG image is re-encoded. The image 
may be re-encoded as a JPEG image or in an alternative encoding format. The final transcoded version of the image 
is also stored in the multi-resolution cache 41 0 via data path 420. 

[0055] In the example embodiment, when additional data requests occur, the HTTP proxy 220 first checks its cache 
410 to see if an "up-to-date" version of the data object is available at the requested resolution or transcoding level 
Each object in the multi-resolution cache 410 is stored with a version specifier that includes: a URL description a time 
stamp for the data object, and the object characteristics. For a JPEG image the object characteristics include color- 
depth, scaling factor, and JPEG quality factor. An alternative embodiment has an indication that the JPEG image has 
been decoded and stored in its bit-map form, or that it has been converted and stored as a GIF with various charac- 
teristics. 

[0056] If an up-to-date version of the object is available with the requested type and resolution, then that version is 
returned to the client. If this is not available, but an up-to-date version of the object exists in either its original JPEG 
form or the decoded bit-map form, then this version is returned to the transcoder 240 with an indication of its charac- 
teristics. This enables the transcoder 240 to produce the desired version of the object, which is returned to the client 
230 and stored in the multi-resolution cache 410 via data path 420. 

[0057] It is noted that there are several extensions to this scheme that are obvious to those skilled in the art One 
extensions uses an already transcoded version of the object, rather than to the original data object to generate a 
further resolution-reduced version of the object. Methods for managing the different resolution versions of data objects 
in a cache are further described in R. O. LaMaire and J. T Robinson, "Conserving Storage Space by Means of Low 
Resolution Objects", docket Y0997308, US patent application filed February 13, 1998. 

[0058] Figure 5 shows an example flow diagram for the dynamic policy module 370 of Figures 3 and 4 Figure 5 also 
shows how the policy module 370 interfaces with the HTTP proxy engine 220 and the object transcoder 240 of Figure 
3. The methods described below apply to many content types including text, images, audio, and video. However the 
following discussion focuses on image data types only. It is evident to those skilled in the art that concepts and dynamic 
policies are applicable to other media types. 

[0059] Figure 5 shows that based on the response header received from the server 21 0, the HTTP proxy engine 220 
first determines the size of the object 51 0. If the content-type of the response is "image/*" 520, the proxy engine 220 
passes the handle for the object to the dynamic policy module 370 for further analysis. Inside the policy module 370 
the size of the input object is compared against a pre configured threshold called "sizejhreshold" 530 If the objects 
is smaller than "sizejhreshold", or the content type is not "image/*" 520, then the object is not transcoded, but instead 
is forwarded 515 to the client without any content modification. Small objects (such as bullets, thumbnails logos etc ) 
found on the web are typically GIF objects which are already well compressed due to GIF encoding. Transcoding such 
objects does not generally yield further compression. 

[0060] We convert GIF images to GIF or JPEG images that are reduced in size and/or color-depth (the choice of 
GIF or JPEG as the end format depends on the image characteristics). In addition, we convert JPEG images to JPEG 
images that are reduced in JPEG quality, size, and/or color-depth. JPEG quality refers to a transcoding parameter that 
is used to determine the degree to which the coefficients of the Discrete Cosine Transformations used in the JPEG 
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encoding standard are quantized. It has been found that the JPEG quality parameter is also a good predictor of per- 
ceived image quality. This parameter varies in the range 1 to 1 00, where 1 00 represents very high quality. JPEG images 
found on the web typically have a JPEG quality parameter of 75. 

[0061] For large images, the type of the image coding (JPEG or GIF) and the efficiency of coding are important 
5 factors in transcoding decision making. Since JPEG is a lossy compression method, size reduction is always possible 
by reducing quality factor. Similar quality reduction, however, cannot be applied to GIF files since GIF is a lossless 
compression method. To achieve quality reduction, a GIF file must first be decoded and then re-encoded as a quality- 
reduced JPEG image. This method, however, may not always provide size reduction . GIF format is usually more efficient 
for coding maps, logos, and drawings while JPEG is more efficient for coding natural images. Converting GIF to JPEG 
10 is useful only when the original GIF image is not efficiently coded. 

[0062) we define bits per pixel (bpp) as a measure of the compression efficiency. Bpp is computed as the ratio of the 
image file size to the image area in pixels. In processing step 540, X and Y dimensions and the bpp value of the input 
image are computed by parsing the image header. If the input object is of type "image/jpg" 550, transcoding is always 
performed. However, if the content type is "image/gif" 525, only those objects which yield a bpp ratio larger than 
is "gifjhreshold" 535 are transcoded. GIF files that are not very efficiently encoded yield a bpp value that is larger than 
"gifjhreshold". Thus, the decision step 535 is very effective in identifying compressible GIF files with high accuracy. 
Though not show in Figure 5, it is evident to those skilled in the art that other transcoding policies, such as scaling and 
file truncation (for progressively encoded data) can be used for well-compressed GIFs. 

[0063] An important aspect of the proposed invention is that decision steps 51 0-565 are carried out as soon as the 
20 image header is received. If the decision is to not transcode, image segments can be forwarded as soon as they are 
received from the server without incurring store and forward delay. Similarly, when transcoding is to be performed, 
images can either be buffered and then transcoded (store and forward transcoding), or each segment can be transcoded 
on-the-fly (streaming transcoding method). 

[0064] After identifying an image that is compressible, the next step involves determining the extent to which the 
25 selected image should be transcoded. The policy function 565 is responsible for collecting input from three different 
sources (image size predictor 375, bandwidth estimator 380, user preference selector 260) and subsequently selecting 
transcoding parameters in accordance with the steps shown in Figure 8. The chosen parameters determine the extent 
and types of compression performed by the object transcoder 240. For example, the scaling parameter determines 
how much an image is downsampled. Quantization parameters control how an image is quantized in the pixel domain 
30 and/or the frequency domain. The number of colors in a color mapped image can be reduced, or a 24-bit color image 
may be converted to 8-bit grayscale, or even a monochrome representation. The process of transcoding is performed 
in step 570 and the output of the transcoder is forwarded to the client 230. 

[0065] An important aspect of the policy function 565 is the analytical framework for making transcoding decisions. 
The analytical framework takes into consideration factors such as available bandwidth, type and size of the image, 

35 user preferences and provides an objective criteria for making transcoding decisions. As an example, we consider the 
objective of minimizing response time for the user, but it is understood by those skilled in the art that using the same 
framework other optimization criteria can also be applied. We describe a method for determining when it is beneficial 
to transcode, and to what extent transcoding should be applied. The embodiment described herein. is referred to as 
dynamic adaptation of transcoding parameters. 

40 [0066] Figure 6 shows an example web request-response cycle and the response time of fetching an object of size 
S through a store-and-forward transcoding proxy 1 90. We define a store-and-forward image transcoder as an image 
transcoder which must wait to accumulate an entire input image before transcoding can begin on this image and then 
must wait to generate a transcoded image in its entirety before it is made available to be output. As shown in Figure 
6, the original image 620 of size S (bytes) 670 is downloaded into the store-and-forward proxy over the server-proxy 

45 connection with effective bandwidth 8^ (bits/sec). The transcoder introduces a delay D^S) 650 and generates an 
output image 630 of size S/Sj 680. Both the transcoding delay 650 and output image's byte size 680 are denoted to 
be dependent upon the input image's byte size S 670. The transcoded image is then transmitted over a proxy-client 
connection having effective bandwidth B^. 

[0067] The policy function needs to weigh the cost (delay) of transcoding against any size reduction achieved by 
50 transcoding. For transcoding to provide benefits, delay introduced due to transcoding must be offset by the reduction 
in transmission time due to compression. For very low bandwidth proxy-client access links, the reduction in response 
time due to aggressive image compression typically far outweighs the addition to response time caused by compute- 
intensive transcoding. However, Figure 7 shows that as the bandwidth of the proxy-client link increases, there comes 
a point (transcoding threshold 71 0) at which it is no longer beneficial to transcode since the reduction in response time 
55 due to aggressive compression decreases as a function of the bottleneck link's bandwidth, while the transcoding time 
remains constant. 

[0068] Suppose R 0 is the response time of fetching a web object of size S from the web server with transcoding 
turned off. Similarly, let R p denote the response time of fetching the transcoded version of the same web object through 
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the transcoding proxy. For the purpose of the following discussion we assume that caching is not supported at the proxy. 
[0069] The client perceived response time with transcoding turned off is the sum of the following three terms: 

R Q =2* RTT pc + 2 * RTT^ + S/min (B pc ,B sp ) 

[0070] RU^ is tne network roundtrip time latency between the client and the proxy and, similarly, RTT $ is the 
latency between the proxy and the server. Fetching the web object requires a TCP SYN/ACK exchange as well as an 
HTTP request/response, thereby contributing 2 * RTT^ + 2 * RJT sp to the delay term. In addition, a web image incurs 
a transmission delay equal to the spread in time between arrival of its first and the last bits. Let min (B pc ,B sp ) denote 
the bottleneck bandwidth between the client and the server. In the absence of a proxy, the first and theTas^bits of an 
image will be spread in time by S/minfB^B^). This spread corresponds to the effective transmission time of the image 
over the concatenated server-to-proxy-to-client connection. 

[0071] when transcoding is turned on, the proxy operates in a store and forward mode. 2 * RTT c + 2* RTT is 
again the fixed component of the response time. D p (S) is the additional term that represents the transcoding delay. 
The resulting response time for the transcoded object can be expressed as: 

R P= 2 * RrT pc+2**TTs P * D P (S) + S/B $p + Sp (SjtB^ 
Transcoding will reduce response time if R p < R Q . That is, 

D p (S) + S/B sp + S p (S)/B pc < S/min (B^B^ 

Clearly, when B pc > B spt R p is always greater than R 0 . On the other hand, when B pc < e w , transcoding is useful if and 
only if: 



D p (S) + SIB sp <{S-S p (S)}fB pc 

[0072] The above equation precisely characterizes the regime in which transcoding reduces response time. Figure 
8 shows a flow diagram of an example policy function constructed using the analytical framework described above. 
81 0 marks the entry point of the policy function. The policy function 800 is called from 565 with the original image object 
size as one of the inputs to the policy function. Variable S is set equal to the input object size and the quality factor q 
is initialized to the best possible initial image quality (for example, the quality of the input image). In step 830, the policy 
function 800 issues a query to the bandwidth estimator 380 asking for the estimated download time of the object size 
S from the specified server to the proxy, referred to as TrfS). It also asks for the estimate of the download time for the 
same object from the proxy to the client, referred to as TgS). Based on the logs of previous connections to the chosen 
destination, the bandwidth estimator returns an estimate of TrfS) and T 2 (S). In the next step 840, the policy function 
queries the image size & delay predictor 375 to find an estimate of the transcoded image size Sp(S). It then computes 
the estimated download time savings by subtracting the download time estimate of the transcoded image size T^S 
(S)) from T 2 (S) 850. Finally, in step 870 the two quantities (transcoding delay + TrfS) - the download savings) and the 
target response time reduction are compared. If the first term is less than the second term, computation is stopped 
and the chosen quality factor q is returned as an output 880. Otherwise, the loop 840-870 is reentered with a reduced 
g value. 

[0073] It is noted that more efficient search techniques or variants of objective functions can be designed by those 
skilled in the art without departing from the spirit of the policy function framework presented in this invention. One 
extension would be to rearrange the terms in the policy equation as follows: 

Response time reduction(q) = {S - S^SftlB^ - D p (S) - S/sB^ 

[0074] In the above equation, S p (S) is also a function of the quality factor (the smaller the output size, the poorer the 
quality). Note that the transcoding delay has been found to be effectively independent of the quality factor. There are 
two independent variables in the above equation: q, the quality factor, and the target response time reduction. Several 
different policies can be developed within the framework of the above equation. For example: 
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Minimize response time for all users; 

Maximize quality for a user specified response time constraint; 

Optimize overall system performance, not just one user. 

5 [0075] Since transcoding is a compute-intensive task and the proxy only has limited CPU power, the proxy's CPU 
cycles are best spent on the set of tasks that maximize overall user satisfaction. During the peak usage period, if every 
user turns transcoding on, there may not be sufficient CPU cycles available to satisfy all transcoding requests. By 
delegating the responsibility of parameter selection to the policy function 800, the system can automatically select the 
optimal transcoding parameters and provide consistent and predictable response to the end user. If users were to 

10 select these parameters independently, the transcoding system could not operate at the optimal performance level. 
[0076] Let us now consider the transcoding delay and size estimation. The decision step 870 requires two additional 
inputs: an estimate of the size of the transcoded image, S p (S), and the transcoding delay, D p (S) } that is incurred during 
the process of transcoding. An accurate prediction of these two quantities is difficult to obtain since they depend on 
the image content, type of coding used, original quality factor, processor speed, and the load on the proxy. As was the 

15 case for the bandwidth estimators, the present invention uses statistical methods to estimate these two quantities. 
[0077] Figure 9 is a block diagram of an example of the image size prediction module in accordance with the present 
invention. As shown in 91 0, we initialize our system with statistical characterizations of S x (q) that are based on a large 
benchmark set of images. The method shown in 91 0 is used to initialize the transcoded image size distribution functions 
that depend on the parameters bpp and q. The proxy continually adds new sample points 920 to the distribution function 

20 as it fetches and transcodes new image objects. The function of 920 enables the image size predictor 375 to adapt its 
behavior to different data sets that a client may be accessing. 

[0078] Thus, in the method described in 930, we use statistical methods to estimate the delay and output size and 
use the bpp ratio as the criteria for performing a more accurate classification of images and hence of forming a better 
estimate of the resulting transcoded file size. This method works particularly well for GIF files. 
25 [0079] Using similar statistical methods, D p (S) can be estimated based on benchmark initialization and on-line up- 
dating of the statistical model, we have also determined from our statistical work, that the transcoding delay is well 
characterized as being a linear function of the number of pixels (as opposed to file size). 

[0080] Now we consider the bandwidth and download time estimation. The accuracy of decision step 870 also de- 
pends to a large extent on the accuracy of image download time estimates. Bandwidth estimator 380 shown in Figures 

30 3-5 is responsible for providing these time estimates. The bandwidth estimator 380 records every packet send and 
receive event at the proxy and performs statistical analysis on the collected traces to make predictions about the state 
of the network. Those skilled in the art of network monitoring recognize that the network monitoring function can be 
implemented in several different ways. One implementation would be a shim layer between the proxy application and 
the socket layer. Another implementation would be a processing layer above any packet filtering software. Generally 

35 the implementation bu ilt over the packet filtering software will provide more accurate estimates of bandwidth and down- 
load time. The present invention presents no requirement that the bandwidth monitor 380 and the policy decision step 
870 should both run on the same machine, though collocating the two modules minimizes the overhead of communi- 
cation between them. 

[0081] Figure 1 0 shows an example bandwidth estimator module 380 in accordance with the present invention. The 
40 module consists of two components; trace monitor 1010 and a statistical analyzer 1 020. The trace monitor continuously 
monitors all connections between the clients and the proxy. The same trace monitor (or another instance of it) is also 
used to monitor the traffic between the proxy and all web servers. For each monitored connection the following infor- 
mation is recorded: 

45 time when a new connection is established, 

source address, source port number and destination address, destination port number of each network connection, 
number of bytes sent and received on each connection and the respective timestamp of each send and receive 
event, 

time when connections are closed. 

50 

[0082] The statistical analyzer 1020 maintains a database of all past and all current active connections. For each 
connection it also keeps a history of when and how many bytes were sent and/or received on that connection. Based 
on this history the statistical analyzer 1 020 is able to make predictions about the download time of future connections. 
For predicting server to proxy download time and proxy to client download time we use different heuristics. 
55 [0083] Server to proxy traces exhibit behavior that is common among wide-area TCP connections. It has been ob- 
served that sequence Vs timestamp traces are non-linear and we have found that linear estimation concepts such as 
average or median bandwidth dont yield accurate estimates. To predict the download time of an object of a given size, 
bandwidth estimator looks at the history of connections to the chosen destination and computes the distribution function 
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of the download time for all objects that have roughly the same size. The median, or some other appropriate statistical 
function of this distribution, is returned as the download time estimate. 

[0084] In contrast, proxy-to-client TCP behavior is dominated by the effects of having a bandwidth constrained link 
which is typically the last hop 160-164. Because there is a bottleneck link, the aggregate of all active TCP connections 
to a client typically saturate the bottleneck link. Thus, for providing proxy to client download time estimates, bandwidth 
estimator aggregates all active connections to a client into a single group. For each group of connections it plots a time 
vs number of bytes plot and then performs a linear curve-fit on the data. This technique provides accurate estimate of 
the current available bandwidth between the proxy and the client. Although this value changes with time, the oscillations 
in most cases are bounded. For example, bandwidth monitor can easily detect whether the client is connected by a 
1 0Mb ethernet, 1 4.4 modem, or 28.8 modem by analyzing at the output of the curve fitting algorithm. The predicted 
values are not exact (20- 30% deviation from the correct values), but those skilled in the art recognize that accuracy 
of bandwidth estimation can be improved by refining the estimation algorithm. 

[0085] Consideration is now given to the transcoding user interface. Transcoding user interface is the interface 
through which the user can dynamically change the tradeoff between image quality and download time. It is represented 
as the item 260 in Figures 2-5. Figure 11 shows an example implementation of the user preference interface in ac- 
cordance with the current invention. This user interface is represented well as a linear slide bar, which can be imple- 
mented as a Java applet, to allow users to continuously vary the image quality. As shown in Figure 11 an option for 
selecting color (vs. gray scale) is also provided. Further, an option for selecting autopilot can be used in the following 
two ways: 1 ) as an indication to the proxy that it can automatically decide whether or not to perform transcoding, based 
on the current estimates of the client-proxy and proxy-server link bandwidths and currently available CPU resources 
as discussed above, or 2) as an indication to the proxy to try and maintain the current download times that the user is 
currently experiencing (i.e., by varying image quality at the proxy to compensate for dynamic bandwidth changes that 
are detected by the bandwidth estimation subsystem), or both 1) and 2) . On occasions when the user requires a full- 
fidelity version of the data, they can easily request the refined data by adjusting the slide bar (downwards) and request- 
ing the higher quality data. Typically, we find that almost all of our web browsing can be done by transcoding images 
to a sixth or tenth of their original size, and only rarely do we actually find a object, such as a map, that we need to 
request a refinement of. Note that alternative HTML-only interfaces can have been invented for supporting non-Java 
devices such as windows CE based platforms. 

[0086] Now we consider streaming image transcoding. The above description is generally applicable to a store-and- 
forward transcoding proxy. Following, we describe conditions under which it is beneficial for a streamed image trans- 
coder to engage in transcoding. A streamed image transcoder is an image transcoder which starts writing out image 
data encoded in an output format before having fully read in the complete input stream of bytes corresponding to the 
entire image encoded in the input format. 

[0087] In Figure 12 we illustrate an example of the reasoning behind our algorithm by using a timing diagram The 
input image arrives as a stream of bits spaced apart by 1IB sp . The streaming image transcoder will take a group of G 
bits for transcoding, incurring a small store-and-forward delay D t . The group of bits are then transcoded into a group 
of G p output bits, incurring a delay D 2 . If D^D h then the image transcoder can convert each input group G to its 
corresponding output group G p before the next input group G needs to be processed. In this case, the streaming image 
transcoder's internal memory requirement is bounded. However, if D^D V then the image transcoder will not be able 
to process input bits fast enough. In this latter case, given a continuous input stream, then the image transcoder's 
internal memory requirement grows without bound, i.e. the image transcoder's finite-length internal RAM buffers will 
overflow. Therefore, we desire than the transcoding delay D 2 satisfy D^D V Clearly, D 1 = GIB . To find D 2 , let D (S) 
= the predicted image transcoding time for an image of S bits (D p (S) actually depends on other* parameters, such as 
image content and dimension, but we use D p (S) for simplicity of notation). Then, D 2 = D p (s)/(S/G). To avoid overflowing 
the RAM buffer, the group transcoding delay must satisfy D p (S)/(S/G) < G/B^, or 



D p (S) < SIB ps (Condition A) 

[0088] Assuming that Condition A holds true, then the output transcoded groups G p will be uniformly spaced by a 
delay equal to D P The transmission channel can send each transcoded group of bits G p in time D 3 = GJB In case 
i), we illustrate Drf) < 0„ i.e. each output group G p can be sent before the next output group is ready for transmission. 
In case ii), D 3 (ii) > D 1t so that the output transmission link cannot send the produced bits fast enough to keep the output 
queue empty. In case ii), the transmission link's output queue grows without bound given a continuous stream of trans- 
coded bits, causing overflow for finite-length link buffers. Therefore, we desire that the delay caused by the transcoded 
output group size D 3 (i) < D,. Clearly, D 3 (i) = GJB pcr To avoid overflowing the transmission link's output buffer, the 
transcoded output image group size G p must satisfy GpiB pc < G/B sp , or 
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c > B P J B pc (Condition B) 

where c = group image compression ratio G/G pi which we assume to be on average equivalent to the overall image 
compression ratio. In summary, the streamed image transcoder should only perform transcoding when both Condition 
A and Condition B are satisfied. If the proxy-server link is the bottleneck, i.e. B cp < B^, then Condition B reduces to c 
> A/, where N is a number less than 1 . Normally, the compression ratio is always greater than 1 , so Condition B will 
always be satisfied. In this case, only Condition A must be satisfied in order for transcoding to not be disadvantageous. 
In fact, when the proxy-server link is the bottleneck, Condition B could be interpreted as providing an upper bound on 
the ratio of expansion allowed for a transcoded image, namely 1/c< B p JB sp . Expansion of an image may occasionally 
be necessary when format conversion is mandatory, e.g. GIF->Palm format. The above equation allows us to determine 
when such format conversion will increase the chances of buffer overflow, and when format conversion will not cause 
buffer overflow. For example, if B sp = 1 b ps , B^ - 2 b ps> and G = 1 bit, then Condition B says that the output group G p 
can expand to a maximum of 2 bits. If the client-proxy link is the bottleneck, i.e. B sp > B pc then Condition B says that 
the image compression ratio c must be greater than the ratio of proxy-server to client-proxy bandwidths in order for 
transcoding to be worthwhile. In addition, Condition A must still be satisfied. 

[0089] It is noted that condition A and condition B are tight bounds that assume that the buffer must never be allowed 
to overflow. Those skilled in the art recognize that looser constraints may be derived given that images are of finite- 
length, rather than the continuous stream assumed in the analysis. More relaxed constraints would permit more time 
for transcoding and/or allow less aggressive compression. 

[0090] It is thus an aspect of the present invention to provide a method for a transcoding proxy to facilitate browsing 
between client devices and servers connected via a communication network. The method includes receiving an HTTP 
GET request from a client devices for an object stored at one of the servers, forwarding the GET request for the object 
to the server, receiving the object from the servers, examining preferences specified by a user of the client device, 
examining contents of the object, examining communication network characteristics, choosing a set of transcoding 
parameters, forming a transcoded form of the object, sending the transcoded form to the client, and/or examining 
network characteristics including estimating network bandwidth between the server and the proxy as well as between 
the proxy and the client, and/or estimating delay between the servers and the proxy as well as delay between the proxy 
and the client device, and/or providing a feedback to the user about a level of transcoding performed on the object, 
and/or the step of examining including determining the size of the object, and/or determining dimensions of the object, 
and/or calculating the compression ratio of the object. If the object is of type image, dimensions of the image object 
are determined by area of the image in square pixels, and the compression ratio is determined by the bpp ratio of the 
■image object. The present invention allows both store-and-forward and streaming transcoding, thus allowing forming 
a transcoded form before the step of receiving the object from the servers is complete. This method can be applied to 
JPEG, GIF and other image types. Another aspect of this invention is that it allows sending out the transcoded form 
before the step of forming a transcoded form of the object is complete. 

[0091 ] There are several other considerations that are important. The above examples for the concepts of the present 
invention are usual for image and video, etc. The wide use of the Internet has shown the value of JPEG and MPEG 
compressed image data. Audio coded data also needs to be decompressed, mixed with special sound effects, merged 
with other audio data, edited and processed in the real domain. Similar implementations are performed for other in- 
dustrial, commercial, and military applications 

[0092] This invention may also be provided as a process, an article of manufacture, apparatus, system, architecture 
and/or a computer product. For example, it may be implemented as an article of manufacture comprising a computer 
usable medium having computer readable program code means embodied therein for causing a computer to perform 
the methods of the present invention. 

[0093] It is noted that although the description of the invention is made for particular arrangements of steps, the 
intent and concept of the present invention are suitable and applicable to other arrangements. For example, the in- 
vention is also adaptable to any browser although embodiment is directed towards web browsing only. Although primary 
consideration is given to dynamic implementations, the invention may be employed with a combination of static, quasi- 
dynamic and dynamic implementations. 



Claims 

1 . A method for a transcoding proxy (220,240,370) to facilitate browsing between a plurality of client devices (230) 
and a plurality of servers (210) connected via a communication network, the method comprising: 
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receiving a request from one of the client devices (230) for an object stored at one of the servers (21 0), 
forwarding the request for the object to said one of the servers (21 0), 
receiving the object from said one of the servers (210), 

examining preferences specified by a user of said one of the client devices (230), 

examining contents of the object, 

examining communication network characteristics, 

choosing a set of transcoding parameters, 

forming a transcoded form of the object by means of the transcoding proxy (220,240,370), and 
sending the transcoded form to said one of the clients (230), 

characterised by; 

setting a variable (S) to the input size of the object, 

estimating a first download time (T^S)) of the object size (S) from the said one of the servers (210) to the 
transcoding proxy (220,240,370) and a second download time (T 2 (S)) of the object size from the transcode proxy 
(220,240,370) to the said one of the clients (230), 

initialising a quality factor (q), 

estimating the size (S p (S)) of the object when transcoded by the transcoding proxy to the quality represented 
by the quality factor (q), 

determining the transcoding delay (D p (S)) to transcode the object, 

estimating a third download time (T 2 (S p (S)) of the transcoded object size from the transcode proxy to the 
said one of the clients, 

computing an estimate from the first, second and third download times (T^S),^), T 2 (S (S))) and the trans- 
coding delay (D p (S)) of the response time reduction effected by transcoding the object, and P 

comparing the estimate of the response time reduction to a preset target and reducing the quality factor (q) 
if the estimate of the response time reduction is less than the target. 

A method as recited in claim 1, wherein the network characteristics includes bandwidth, and examining network 
characteristics includes estimating network bandwidth between said one of the servers (210) and the proxy 
(220,240,370) as well as between the proxy (220,240,370) and said one of the clients (230). 

A method as recited in any preceding claim, further comprising providing feedback to the user (230) about a level 
of transcoding performed on the object to form the transcoded form. 

A method as recited in any preceding claim, wherein the step of forming a transcoded form employs dynamic 
adaptation. 

A method as recited in any preceding claim, wherein the step of forming a transcoded form is started before the 
step of receiving the object from said one of the servers (21 0) is complete. 

A method as recited in any preceding claim, wherein the step of sending out the transcoded form is started after 
processing an initial fraction of the received object, and before the step of receiving the image object from said 
one of the servers (21 0) is complete. 

A method as recited in any preceding claim 1 , wherein the step of sending out the transcoded form is started before 
the step of forming a transcoded form of the object is complete. 

A communication system including a transcoding proxy (220, 240, 370) to facilitate browsing between a plurality 
of client devices (230) and a plurality of servers (210) connected via a communication network, the system com- 
prising: 

means to receive a request from one of the client devices (230) for an object stored at one of the servers (210), 
means to forward the request for the object to said one of the servers (210), 
means to receive the object from said one of the servers (21 0), 

means to examine preferences specified by a user of said one of the client devices (230), 

means to examine contents of the object, 

means to examine communication network characteristics, 

means to choose a set of transcoding parameters, 

means to form a transcoded form of the object by means of the transcoding proxy (220,240,370), and 
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means to send the transcoded form to said one of the clients (230), 

characterised by; 

means to set a variable (S) to the input size of the object, 

means to estimate a first download time (T^S)) of the object size (S) from the said one of the servers (21 0) 
to the transcoding proxy (220,240,370) and a second download time (T 2 (S)) of the object size from the transcode 
proxy (220,240,370) to the said one of the clients (230), 

means to initialise a quality factor (q), 

means to estimate the size (S p (S)) of the object when transcoded to the quality represented by the quality 
factor (q), 

means to determine the transcoding delay (D p (S)) to transcode the object, 

means to estimate a third download time (T 2 (S p (S))) of the transcoded object size from the transcode proxy 
to the said one of the clients, 

means to compute an estimate from the first, second and third download times (T 1 (S), T 2 (S), T 2 (S p (S))) and 
the transcoding delay (D p (S)) of the response time reduction effected by transcoding the object, and 

means to compare the estimate of the response time reduction to a preset target and reduce the quality 
factor (q) if the estimate of the response time reduction is less than the target. 

9. A computer program comprising computer program instructions to cause a computer to perform the steps of the 
method as claimed in any of claims 1 to 7. 



Patentansp ruche 

1. Verfahren fur einen Transcodierungs-Proxy (220, 240, 370), urn das Durchsuchen(Browsing) einer Vielzahl von 
Client-Einheiten (230) und einer Vielzahl von Servern (210), die uber ein Kommunikationsnetzwerk verbunden 
sind, zu vereinfachen, wobei das Verfahren Folgendes umfasst: 

Empfangen einer Anforderung von einer der Client-Einheiten (230) fur ein Objekt, das auf einem der Server 
(210) gespeichert ist, 

Weiterleiten der Anforderung fur das Objekt an den einen der Server (210), 
Empfangen des Objekts von dem einen der Server (210), 

Prufen von Voreinstellungen, die von einem Benutzer von der einen der Client-Einheiten (230) festgelegt wur- 
den, 

Prufen des In halts des Objekts, 

Prufen von Eigenschaften des Kommunikationsnetzwerks, 
Wahlen eines Satzes von Transcodierungsparametern, 

Bilden einer transcodierten Form des Objekts mittels des Transcodierungs-Proxy (220, 240, 370), und 
Senden der transcodierten Form an den einen der Clients (230), 
gekennzeichnet durch: 

Setzen einer Variablen (S) auf die EingangsgroBe des Objekts, 

Schatzen eines ersten Zeitraums (T, (S)) fur das Herunterladen der Objektgr63e (S) von dem einen der Server 
(210) auf den Transcodierungs-Proxy (220, 240, 370) und eines zweiten Zeitraums (T 2 (S)) fur das Herunter- 
laden der ObjektgroBe von dem Transcodierungs-Proxy (220, 240, 370) auf den einen der Clients (230), 

Setzen eines Qualitatsfaktors (q) auf einen Anfangswert, 
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Schatzen der GroBe (S p (S)) des Objekts, wenn es von dem Transcodierungs- Proxy in die von dem Qualitats- 
faktor (q) dargestellte Qualitat transcodiert wurde, 

Ermitteln derTranscodierungsverzogerung, (D p (S)), urn das Objekt zu transcodteren, 

Schatzen eines dritten Zeitraums (T 2 (S p (S))) fur das Herunterladen der GroGe des transcodierten Objekts von 
dem Transcodierungs-Proxy auf den einen der Clients, 

Berechnen eines Schatzwerts der Verringerung der Antwortzeit aus dem ersten, dem zweiten und dem dritten 
Zeitraum fur das Herunterladen (T^S), T 2 (S), T 2 (S p (S)) und derTranscodierungsverzogerung (D (S)), wobei 
die Verringerung durch die Transcodierung des Objekts bewirkt wird, und 

Vergleichen des Schatzwerts der Verringerung der Antwortzeit mit einem voreingestellten Zielwert und Ver- 
ringern des Qualitatsfaktors (q), wenn der Schatzwert der Verringerung der Antwortzeit unter dem Zielwert 
liegt. 

2. Verfahren nach Anspruch 1 , wobei zu den Netzwerkeigenschaften die Bandbreite gehort und wobei die Prufung 
der Netzwerkeigenschaften das Schatzen der Netzwerkbandbreite zwischen dem einen der Server (21 0) und dem 
Proxy (220, 240, 370) sowie zwischen dem Proxy (220, 240, 370) und dem einen der Clients (230) beinhaltet. 

3. Verfahren nach einem der vorhergehenden Anspruche, das des Weiteren die Bereitstellung einer Ruckmeldung 
an den Benutzer (230) uber den Grad der Transcodierung umfasst, die an dem Objekt durchgefuhrt wird, urn die 
transcodierte Form zu bilden. 

4. Verfahren nach einem der vorhergehenden Anspruche, wobei der Schritt der Bildung einer transcodierten Form 
eine dynamische Anpassung vornimmt. 

5. Verfahren nach einem der vorhergehenden Anspruche, wobei der Schritt der Bildung einer transcodierten Form 
gestartet wird, bevor der Schritt des Empfangs des Objekts von dem einen der Server (21 0) abgeschlossen ist. 

6. Verfahren nach einem der vorhergehenden Anspruche, wobei der Schritt des Versendens der transcodierten Form 
gestartet wird, nachdem ein erster Teil des empfangenen Objekts verarbeitet wurde und bevor der Schritt des 
Empfangs des Bildobjekts von dem einen der Server (210) abgeschlossen ist. 

7. Verfahren nach dem vorhergehenden Anspruch 1, wobei der Schritt des Versendens der transcodierten Form 
gestartet wird, bevor der Schritt der Bildung einer transcodierten Form des Objekts abgeschlossen ist. 

8. Kommunikationssystem, das einen Transcodierungs-Proxy (220, 240, 370) beinhaltet, urn das Durchsuchen 
(Browsing) einer Vielzahl von Client-Einheiten (230) und einer Vielzahl von Servern (210), die uber ein Kommu- 
nikationsnetzwerk verbunden sind, zu vereinfachen, wobei das System Folgendes umfasst: 

ein Mittel, urn eine Anforderung von einer der Client-Einheiten (230) fur ein Objekt zu empfangen, das auf 
einem der Server (210) gespeichert ist, 

ein Mittel, um die Anforderung fur das Objekt an den einen der Server (210) weiterzuleiten, 
ein Mittel, um das Objekt von dem einen der Server (210) zu empfangen, 

ein Mittel, um Voreinstellungen zu prufen, die von einem Benutzer von der einen der Client-Einheiten (230) 
festgelegt wurden, 

ein Mittel, um den Inhalt des Objekts zu prufen, 

ein Mittel, um Eigenschaften des Kommunikationsnetzwerks zu prufen, 

ein Mittel, um einen Satz von Transcodierungsparametem zu wahlen, 

ein Mittel, um eine transcodierte Form des Objekts mittels des Transcodierungs-Proxy (220, 240, 370) zu 
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bilden, und 

ein Mittel, urn die transcodierte Form an den einen der Clients (230) zu senden, 
gekennzeichnet durch: 

ein Mittel, um eine Variable (S) auf die EingangsgroGe des Objekts zu setzen, 

ein Mittel, um einen ersten Zeitraum (T^S)) fur das Herunterladen der ObjektgroGe (S) von dem einen der 
Server (21 0) auf den Transcodierungs- Proxy (220, 240, 370) und einen zweiten Zeitraum (T 2 (S)) fur das Her- 
unterladen der ObjektgroGe von dem Transcodierungs-Proxy (220, 240, 370) auf den einen der Clients (230) 
zu schatzen, 

ein Mittel, um einen Qualitatsfaktor (q) auf einen Anfangswert zu setzen, 

ein Mittel, um die GroGe (S p (S)) des Objekts zu schatzen, wenn es in die von dem Qualitatsfaktor (q) darge- 
stellte Qualitat transcodiert wurde, 

ein Mittel, um die Transcodierungsverzogerung (D p (S)) zu ermitteln, um das Objektzu transcodieren, 

ein Mittel, um einen dritten Zeitraum (T 2 (S p (S))) fur das Herunterladen der GroGe des transcodierten Objekts 
von dem Transcodierungs-Proxy auf den einen der Clients zu schatzen, 

ein Mittel, um einen Schatzwert der Verringerung der Antwortzeit aus dem ersten, dem zweiten und dem dritten 
Zeitraum fur das Herunterladen (T^S), T 2 (S), T 2 (S p (S))) und der Transcodierungsverzogerung (D p (S)) zu 
berechnen, wobei die Verringerung durch die Transcodierung des Objekts bewirkt wird, und 

ein Mittel, um den Schatzwert der Verringerung der Antwortzeit mit einem voreingestellten Zielwert zu verglei- 
chen und um den Qualitatsfaktor (q) zu verringern, wenn der Schatzwert der Verringerung der Antwortzeit 
unter dem Zielwert liegt. 

9. Rechnerprogramm, das Rechnerprogrammbefehle umfasst, um einen Rechner zur Durchfuhrung der Schritte des 
Verfahrens nach einem der Anspruche 1 bis 7 zu veranlassen. 



Revendications 

1. Un procede permettant a un serveur de proximite a transcodage (220, 240, 370) de faciliter la navigation entre 
une plurality de dispositifs clients (230) et une pluralite de serveurs (210), connectes via un reseau de communi- 
cation, le procede comprenant : 

la reception d'une requete emanant d'un des dispositifs client (230) pour un objet stocke sur Tun des serveurs 
(210), 

la transmission de la requete concernant I'objet audit Tun des serveurs (210), 
la reception de I'objet depuis ledit un des serveurs (210), 

I'examen des preferences specifies par un utilisateur dudit un des dispositifs client (230), 
I'examen des contenus de I'objet, 

I'examen des caracteristiques du reseau de communication, 
le choix d'un jeu de parametres de transcodage, 

la formation d'une forme transcodee de I'objet au moyen du serveur de proximit6 de transcodage (220, 240, 
370), et 
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renvoi de la forme transcodee audit Tun des clients (230), 
caracterise par : 

la fixation d'une variable (S) a la taille d'entree de I'objet, 

I'estimation d'un premier temps de dechargement (T^S)) de la taille d'objet (S) depuis ledit un des serveurs 
(210) au serveur de proximite de transcodage (220, 240, 370) et un deuxieme temps de dechargement (T 2 
(S)) de la taille d'objet du serveur de proximite de transcodage (220, 240, 370) audit I'un des clients (230), 

I'initialisation d'un facteur de qualite (q), 

I'estimation de la taille (S p (S)) de I'objet lorsqu'il y a transcodage par le serveur de proximite a transcodage, 
a la qualite representee par le facteur de qualite (q), 

la determination du delai de transcodage (D p (S)) pour transcoder I'objet, 

I'estimation d'un troisieme temps de dechargement ((T 2 (S p (S))) de la taille d'objet transcode, d'apres le 
serveur de proximite a transcodage audit I'un des clients, 

le calcul d'une estimation a partir des premier, deuxieme et troisieme temps de dechargement (Tj (S), (T 2 (S), 
0*2 (S). T 2 (S p (S))) et du delai de transcodage Dp (S)) de la reduction du temps de reponse effectue par le 
transcodage de I'objet, et 

la comparaison de I'estimation de la reduction du temps de reponse a une cible preetablie et la reduction du 
facteur de qualite (q), si I'estimation de la reduction de temps de reponse est inferieure a la cible. 

Un procede selon la revendication 1 , dans lequel les caracteristiques de reseau comprennent la largeur de bande, 
et I'examen des caracteristiques de r£seau comprend I'estimation de la largeur de bande de reseau entre ledit un 
des serveurs (210) et le serveur de proximite (220, 240, 370), ainsi qu'entre le serveur de proximite (220, 240, 
370) et ledit un des clients (230). 

Un procede selon I'une quelconque des revendications. precedentes, comprenant en outre la fourniture d'une 
retroaction a I'utilisateur (230), concernant un niveau de transcodage, effectuee sur I'objet afin de former la forme 
transcodee. 

Un procede selon I'une quelconque des revendications precedentes, dans lequel I'etape de formation d'une forme 
transcodee utilise une adaptation dynamique. 

Un procede selon I'une quelconque des revendications precedentes, dans lequel I'etape de formation d'une forme 
transcodee est lancee avant que I'etape de reception de I'objet depuis ledit un des serveurs (210) soit achevee. 

Un procede selon I'une quelconque des revendications precedentes, dans lequel I'etape d'envoi de la forme trans- 
codee est lancee apres le traitement d'une fraction initiale de I'objet recu, et avant que I'etape de reception de 
I'objet image depuis ledit un des serveurs (210) soit achevee. 

Un procede selon la revendication 1 , dans lequel I'etape d'envoi de la forme transcodee est lancee avant que 
I'etape de formation d'une forme transcodee soit achevee. 

Un systeme de communication incluant un serveur de proximite a transcodage (220, 240, 370), pour faciliter la 
navigation entre une pluralite de dispositifs client (230) et une pluralite de serveurs (21 0), connects via un reseau 
de communication, le procede comprenant : 

des moyens pour recevoir une requete depuis I'un des dispositifs client (230) pour un objet stocke sur I'un des 
serveurs (210), 

des moyens pour transmettre la requete concernant I'objet audit I'un des serveurs (210), 
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des moyens pour recevoir I'objet depuis ledit un des serveurs (210), 

des moyens pour examiner les preferences specifiers par un utilisateur dudit un des dispositifs client (230), 
des moyens pour examiner les contenus de I'objet, 

des moyens pour examiner les caracteristiques du reseau de communication, 
des moyens pour choisir un jeu de parametres de transcodage, 

des moyens pour former une forme transcodee de I'objet au moyen du serveur de proximite de transcodage 
(220, 240, 370), et 

des moyens pour envoyer la forme transcodee audit I'un des clients (230), 
caracterise par : 

des moyens pour fixer une variable (S) a la taille d'entrSe de I'objet, 

des moyens pour estimer un premier temps de dechargement (T 1 (S)) de la taille d'objet (S) a partir dudit un 
des serveurs (21 0) au serveur de proximite de transcodage (220, 240, 370) et un deuxieme temps de dechar- 
gement (T 2 (S)) de la taille d'objet a partir du serveur de proximite de transcodage (220, 240, 370) audit I'un 
des clients (230), 

des moyens pour initialiser un facteur de qualite (q), 

des moyens pour estimer la taille (Sp (S)) de I'objet lorsqu'il y a transcodage par le serveur de proximite a 
transcodage, a la qualite representee par le facteur de qualite (q), 

des moyens pour determiner le delai de transcodage (D p (S)) pour transcoder I'objet, 

des moyens pour estimer un troisieme temps de dechargement ((T 2 (S p (S))) de la taille d'objet transcode, 
d'apres le serveur de proximite a transcodage audit Tun des clients, 

des moyens pour calculer une estimation a partir des premier, deuxieme et troisieme temps de dechargement 
(T^ (S), (T 2 (S), (T 2 ( S), T 2 (S p (S))) et du delai de transcodage Dp (S)) de la reduction du temps de reponse 
effectue par le transcodage de I'objet, et 

des moyens pour comparer I'estimation de la reduction du temps de reponse a une cible pre6tablie et la 
reduction du facteur de qualite (q) si I'estimation de la reduction de temps de reponse est inferieure a la cible. 

Un programme d'ordinateur comprenant des instructions de programme d'ordinateur, pour faire effectuer par un 
ordinateur les etapes du procede tel qu'indique a I'une quelconque des revendications 1 a 7. 
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